Query Operators (Comparison, Logical, Element) গাইড ও নোট

Database Tutorials - মঙ্গোডিবি (MongoDB) - MongoDB Query Language (MQL)
356

MongoDB তে কুয়েরি অপারেটরগুলি ব্যবহার করা হয় ডেটা অনুসন্ধান এবং প্রক্রিয়া করার জন্য। এই অপারেটরগুলি বিভিন্ন ধরনের শর্তের ভিত্তিতে ডেটা নির্বাচন করতে সহায়তা করে। MongoDB তে তিন ধরনের প্রধান কুয়েরি অপারেটর রয়েছে: তুলনা অপারেটর, লজিক্যাল অপারেটর, এবং এলিমেন্ট অপারেটর


1. তুলনা অপারেটর (Comparison Operators)

তুলনা অপারেটরগুলি ডেটার মানের ভিত্তিতে ডেটা অনুসন্ধান করতে ব্যবহৃত হয়।

  • $eq (সমান): ডেটার মানের সাথে সমান থাকা ডকুমেন্টগুলি মেলে।

    db.collection.find({ age: { $eq: 30 } })
    
  • $ne (অসমান): ডেটার মানের সাথে অসমান থাকা ডকুমেন্টগুলি মেলে।

    db.collection.find({ age: { $ne: 30 } })
    
  • $gt (বড়): ডেটার মান যেগুলোর থেকে বড়, সেগুলিকে মেলে।

    db.collection.find({ age: { $gt: 30 } })
    
  • $gte (বড় অথবা সমান): ডেটার মান যেগুলোর থেকে বড় অথবা সমান, সেগুলিকে মেলে।

    db.collection.find({ age: { $gte: 30 } })
    
  • $lt (ছোট): ডেটার মান যেগুলোর থেকে ছোট, সেগুলিকে মেলে।

    db.collection.find({ age: { $lt: 30 } })
    
  • $lte (ছোট অথবা সমান): ডেটার মান যেগুলোর থেকে ছোট অথবা সমান, সেগুলিকে মেলে।

    db.collection.find({ age: { $lte: 30 } })
    
  • $in (ভিতরে): একটি নির্দিষ্ট মান যেগুলোর মধ্যে থাকে, সেগুলি মেলে।

    db.collection.find({ age: { $in: [30, 40, 50] } })
    
  • $nin (ভিতরে নয়): একটি নির্দিষ্ট মান যেগুলোর মধ্যে নেই, সেগুলি মেলে।

    db.collection.find({ age: { $nin: [30, 40, 50] } })
    

2. লজিক্যাল অপারেটর (Logical Operators)

লজিক্যাল অপারেটরগুলি একাধিক শর্তের ভিত্তিতে ডেটা নির্বাচন করতে ব্যবহৃত হয়।

  • $and (এবং): একাধিক শর্তের মধ্যে সব শর্ত মেনে চলা ডকুমেন্টগুলি মেলে।

    db.collection.find({ $and: [{ age: { $gte: 30 } }, { age: { $lt: 40 } }] })
    
  • $or (অথবা): একাধিক শর্তের মধ্যে যেকোনো একটি শর্ত পূর্ণ হলে ডকুমেন্ট মেলে।

    db.collection.find({ $or: [{ age: { $lte: 30 } }, { age: { $gte: 40 } }] })
    
  • $not (নট): একটি শর্তের বিপরীত ডকুমেন্ট মেলে।

    db.collection.find({ age: { $not: { $gte: 30 } } })
    
  • $nor (অথবা নয়): একাধিক শর্তের মধ্যে সব শর্ত পূর্ণ না হলে ডকুমেন্ট মেলে।

    db.collection.find({ $nor: [{ age: { $gte: 30 } }, { age: { $lte: 20 } }] })
    

3. এলিমেন্ট অপারেটর (Element Operators)

এলিমেন্ট অপারেটরগুলি ডেটার উপস্থিতি বা ডেটার টাইপ পরীক্ষা করতে ব্যবহৃত হয়।

  • $exists (অস্তিত্ব): একটি ফিল্ড ডকুমেন্টে রয়েছে কিনা তা চেক করতে ব্যবহৃত হয়। এটি true বা false হতে পারে।

    • true: ফিল্ডটি বিদ্যমান ডকুমেন্টগুলি মেলে।
    • false: ফিল্ডটি অনুপস্থিত ডকুমেন্টগুলি মেলে।
    db.collection.find({ age: { $exists: true } })
    db.collection.find({ age: { $exists: false } })
    
  • $type (টাইপ): একটি ফিল্ড নির্দিষ্ট BSON টাইপের কিনা তা চেক করতে ব্যবহৃত হয়।

    db.collection.find({ age: { $type: "int" } })
    db.collection.find({ age: { $type: 16 } })  // 16 হল BSON টাইপ `int`
    

উদাহরণ কুয়েরি

  • তুলনা অপারেটর ব্যবহার করে: বয়স ৩০ এর কম বা ৬০ এর বেশি ব্যবহারকারীদের খুঁজুন।

    db.users.find({ age: { $lt: 30, $gt: 60 } })
    
  • লজিক্যাল অপারেটর ব্যবহার করে: বয়স ৩০ এর বেশি বা ২০ এর কম ব্যবহারকারীদের খুঁজুন।

    db.users.find({ $or: [{ age: { $gt: 30 } }, { age: { $lt: 20 } }] })
    
  • এলিমেন্ট অপারেটর ব্যবহার করে: যেখানে age ফিল্ড উপস্থিত।

    db.users.find({ age: { $exists: true } })
    
  • $in ব্যবহার করে: বয়স ২৫, ৩০ অথবা ৩৫ এর মধ্যে ব্যবহারকারীদের খুঁজুন।

    db.users.find({ age: { $in: [25, 30, 35] } })
    

সারাংশ

MongoDB তে তুলনা অপারেটর, লজিক্যাল অপারেটর, এবং এলিমেন্ট অপারেটর ডেটাবেসে ডেটা অনুসন্ধানে অত্যন্ত শক্তিশালী টুল হিসেবে কাজ করে। তুলনা অপারেটর ব্যবহার করে ডেটার মানের ভিত্তিতে কুয়েরি করা যায়, লজিক্যাল অপারেটর ব্যবহার করে একাধিক শর্তকে যুক্ত বা বিপরীতভাবে কাজ করা যায়, এবং এলিমেন্ট অপারেটর ব্যবহার করে ডেটার উপস্থিতি বা টাইপ চেক করা যায়। এই অপারেটরগুলি MongoDB ডেটাবেসে খুবই নমনীয় এবং জটিল কুয়েরি তৈরি করতে সহায়তা করে।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...